Engineering Sector Digital Electronics Design Diploma Eng. Kareem Waseem

# Project 1 Spartan-6 FPGA DSP48A1 Slice

**BY: Youssef Ekramy** 

Under the supervision of:

Eng. Kareem Waseem

# **Table of Contents**

| 1 | DSI  | P 48A1 Module                     | 3   |
|---|------|-----------------------------------|-----|
|   | 1.1  | Code                              | 3   |
|   | 1.2  | Testbench Code                    | 9   |
|   | 1.3  | Do file                           | .12 |
|   | 1.4  | Waveform                          | .13 |
|   | 1.5  | Constraint File                   | .14 |
|   | 1.6  | RTL snippets                      | .14 |
|   | 1.7  | Elaboration messages              | .14 |
|   | 1.8  | Synthesis Schematic               | .15 |
|   | 1.9  | Synthesis Messages                | .16 |
|   | 1.10 | Synthesis Utilization report      | .19 |
|   | 1.11 | Synthesis Timing Report           | .20 |
|   | 1.12 | Implementation Schematic          | .20 |
|   | 1.13 | Implementation Messages           | .20 |
|   | 1.14 | Implementation Utilization Report | .21 |
|   | 1.15 | Implementation Timing Report      | 22  |

#### 1 DSP 48A1 Module

#### **1.1** Code

```
module reg mux pipeline #(
    /* This attribute determines if there is register or not
       1 => Registered
                                         (DEFAULT)
        0 => NO Register
    parameter REG = 1,
    /* This attribute determines the width of the inputs */
    parameter WIDTH = 18,
    /* It selects whether all resets asynchronous /synchronous
       "ASYNC" => Asynchronous
       "SYNC" => Synchronous
                                                   (DEFAULT) */
    parameter RSTTYPE = "SYNC"
) (
    input clk, enable, rst,
    input [WIDTH-1:0] in,
    output [WIDTH-1:0] out
);
    generate
        if (REG == 1) begin
            reg [WIDTH-1:0] in r;
            if(RSTTYPE == "ASYNC")
                always @(posedge clk or posedge rst) begin
                    if(rst)
                        in r <= 0;
                    else if(enable)
                        in_r <= in;</pre>
                end
            else if(RSTTYPE == "SYNC")
                always @(posedge clk) begin
                    if(rst)
                         in_r <= 0;
                    else if(enable)
                        in_r <= in;</pre>
                end
            assign out = in_r;
        else
            assign out = in;
    endgenerate
endmodule
```

```
module DSP48A1Module #(
    /* A0 and B0 are the first stages of the pipelines
       A1 and B1 are the second stages of the pipelines */
   parameter AOREG = 0, parameter BOREG = 0, // Default: NO registers
   parameter A1REG = 1, parameter B1REG = 1, // Default: registered
   /* The number defines the number of pipeline stages. */
   parameter CREG = 1, parameter DREG = 1,
   parameter MREG = 1, parameter PREG = 1,
   parameter CARRYINREG = 1, parameter CARRYOUTREG = 1,
   parameter OPMODEREG = 1,
   /* The CARRYINSEL attribute is used in carry cascade input
       "CARRYIN" => the CARRYIN input will be considered
       "OPMODE5" => the value of opcode[5] (DEFAULT)
                 => if none of these string values exist. */
   parameter CARRYINSEL = "OPMODE5",
   /* It defines whether the input to the B port is routed
       "DIRECT" => routed from the B input (DEFAULT)
       "CASCADE" => the cascaded input (BCIN) from the previous DSP48A1 slice
               => if none of these string values exist. */
   parameter B_INPUT = "DIRECT",
   /* It selects whether all resets asynchronous /synchronous
      "ASYNC" => Asynchronous
                                                (DEFAULT) */
   parameter RSTTYPE = "SYNC"
   input [17:0] A, B, D,
   input [47:0] C,
   input CARRYIN,
   output [35:0] M,
   output [47:0] P,
   output CARRYOUT, CARRYOUTF,
   /* Control Input Ports */
   input clk,
   input [7:0] OPMODE,
   /* Clock Enable Input Ports */
   input CEA, CEB, CEC,
   input CED, CEM, CEP,
   input CEOPMODE, CECARRYIN,
   /* Reset Input Ports */
   input RSTA, RSTB, RSTC,
    input RSTD, RSTM, RSTP,
    input RSTOPMODE, RSTCARRYIN,
```

```
/* Cascade Ports */
    input [17:0] BCIN,
    output [17:0] BCOUT,
    input [47:0] PCIN,
    output [47:0] PCOUT
);
   /* First pipeline stage of inputs
    reg [17:0] B0_in; // Handling the input of B0
    always @(*) begin
        case(B_INPUT)
        "DIRECT": B0_in = B;
        "CASCADE": B0 in = BCIN;
        default: B0_in = 0;
        endcase
   wire [17:0] A0_out, B0_out, D_out; // Outputs of first pipeline stage
   wire [47:0] C_out; wire [7:0] OPMODE_out;
    reg_mux_pipeline #(.REG(A0REG),.RSTTYPE(RSTTYPE)) in_A0 (.clk(clk),
                                                             .enable(CEA),
                                                             .rst(RSTA),
                                                             .in(A),
                                                             .out(A0_out));
    reg_mux_pipeline #(.REG(BOREG),.RSTTYPE(RSTTYPE)) in_BO (.clk(clk),
                                                             .enable(CEB),
                                                             .rst(RSTB),
                                                             .in(B0_in),
                                                             .out(B0_out));
    reg_mux_pipeline #(.REG(CREG),.WIDTH(48),.RSTTYPE(RSTTYPE)) in_C (.clk(clk),
                                                                     .enable(CEC),
                                                                     .rst(RSTC),
                                                                     .in(C),
                                                                     .out(C_out));
    reg_mux_pipeline #(.REG(DREG),.RSTTYPE(RSTTYPE)) in_D (.clk(clk),
                                                             .enable(CED),
                                                             .rst(RSTD),
                                                             .in(D),
                                                             .out(D_out));
    reg mux pipeline #(.REG(OPMODEREG),.WIDTH(8),.RSTTYPE(RSTTYPE)) in_OPMODE (.clk(clk),
                                                                                  .enable(CE
OPMODE),
```

```
.rst(RSTOP
MODE),
                                                                                  .in(OPMODE
                                                                                  .out(OPMOD
E_out));
       PRE-ADDER/SUBTRACTOR level*/
   wire [17:0] PRE_ADD_SUB_out;
   assign PRE_ADD_SUB_out = (OPMODE_out[6] == 0)?
                             (D_out + B0_out):
                             (D_out - B0_out);
    /* Second pipeline stage of inputs
        instance name in_(name of Input)
   wire [17:0] B1_in; // Handling the input of B1
   assign B1_in = (OPMODE_out[4] == 0)? B0_out : PRE_ADD_SUB_out;
   wire [17:0] A1_out, B1_out;
   reg_mux_pipeline #(.REG(A1REG),.RSTTYPE(RSTTYPE)) in_A1 (.clk(clk),
                                                             .enable(CEA),
                                                             .rst(RSTA),
                                                             .in(A0_out),
                                                             .out(A1 out));
    reg_mux_pipeline #(.REG(B1REG),.RSTTYPE(RSTTYPE)) in_B1 (.clk(clk),
                                                             .enable(CEB),
                                                             .rst(RSTB),
                                                             .in(B1_in),
                                                             .out(B1_out));
   assign BCOUT = B1_out;
   /* MULTIPLIER level */
   wire [35:0] Multiplier_out;
    assign Multiplier_out = A1_out * B1_out;
   wire [35:0] M_out;
    reg_mux_pipeline #(.REG(MREG),.WIDTH(36),.RSTTYPE(RSTTYPE)) in_M (.clk(clk),
                                                                     .enable(CEM),
                                                                     .rst(RSTM),
                                                                     .in(Multiplier_out),
                                                                     .out(M_out));
   assign M = M_out; //Buffered M Output
   /* MUX X level */
    reg [47:0] X_out;
   wire [47:0] P_out;
```

```
always @(*) begin
        case (OPMODE out[1:0])
            0: X_out = 0; // disable the post-adder/subtracter and propagate the MUX Z
result to P
            1: X out = {{12{1'b0}}, M out}; // Use the multiplier product
            2: X_out = P_out; // Use the P output signal (accumulator)
            3: X_out = {D_out[11:0],A1_out[17:0],B1_out[17:0]}; // Use the concatenated
D:A:B input signals
        endcase
    end
   /* MUX Z level */
    reg [47:0] Z_out;
    always @(*) begin
        case (OPMODE_out[3:2])
            0: Z out = 0; //disable the post-adder/subtracter and propagate the multiplier
product or other X result to P)
           1: Z_out = PCIN;
            2: Z_out = P_out;
            3: Z_out = C_out;
        endcase
    /* CARRYIN POST ADDER/SUBTRACTOR level */
    reg CYI in;
    wire CYI_out;
    always @(*) begin
        case (CARRYINSEL)
            "CARRYIN": CYI_in = CARRYIN;
            "OPMODE5": CYI_in = OPMODE_out[5];
            default: CYI_in = 0;
        endcase
    reg_mux_pipeline #(.REG(CARRYINREG),.WIDTH(1),.RSTTYPE(RSTTYPE)) in_CYI(.clk(clk),
                                                                             .enable(CECARR
YIN),
                                                                             .rst(RSTCARRYI
N),
                                                                             .in(CYI_in),
                                                                              .out(CYI_out))
    /* POST-ADDER/SUBTRACTOR level*/
   wire [47:0] POST_ADD_SUB_out;
   wire CYO_in,CYO_out;
    assign {CYO in,POST ADD SUB out} = (OPMODE out[7] == 0)?
                                        (Z_out + X_out + CYI_out):
                                        (Z_out - (X_out + CYI_out));
    /* P pipeline register */
```

```
reg_mux_pipeline #(.REG(PREG),.WIDTH(48),.RSTTYPE(RSTTYPE)) in_P(.clk(clk),
                                                                      .enable(CEP),
                                                                      .rst(RSTP),
                                                                      .in(POST_ADD_SUB_out),
                                                                      .out(P_out));
    assign P = P_out; assign PCOUT = P_out;
    /* CARRYOUT POST ADDER/SUBTRACTOR level */
    reg_mux_pipeline #(.REG(CARRYOUTREG),.WIDTH(1),.RSTTYPE(RSTTYPE)) in_CYO(.clk(clk),
                                                                              .enable(CECARR
YIN),
                                                                              .rst(RSTCARRYI
N),
                                                                              .in(CYO_in),
                                                                              .out(CYO_out))
    assign CARRYOUT = CYO_out; assign CARRYOUTF =
CYO_out;
endmodule
```

#### 1.2 Testbench Code

```
module DSP48A1Module tb();
   /* Add All the parameters */
   parameter AOREG = 0; parameter BOREG = 0;
   parameter A1REG = 1; parameter B1REG = 1;
   parameter CREG = 1; parameter DREG = 1;
   parameter MREG = 1; parameter PREG = 1;
   parameter CARRYINREG = 1; parameter CARRYOUTREG = 1;
   parameter OPMODEREG = 1;
   parameter CARRYINSEL = "OPMODE5"; parameter B INPUT = "DIRECT";
   parameter RSTTYPE = "SYNC";
   /* Add all the inputs */
   /* Data Ports */
   reg [17:0] A, B, D;
   reg [47:0] C;
   reg CARRYIN;
   wire [35:0] M;
   wire [47:0] P;
   wire CARRYOUT, CARRYOUTF;
   /* Control Input Ports */
   reg clk;
   reg [7:0] OPMODE;
   /* Clock Enable Input Ports */
   reg CEA, CEB, CEC;
   reg CED, CEM, CEP;
   reg CEOPMODE, CECARRYIN;
   /* Reset Input Ports */
   reg RSTA, RSTB, RSTC;
   reg RSTD, RSTM, RSTP;
   reg RSTOPMODE, RSTCARRYIN;
   /* Cascade Ports */
   reg [17:0] BCIN;
   wire [17:0] BCOUT;
   reg [47:0] PCIN;
   wire [47:0] PCOUT;
   /* Self Checker Port*/
   reg [47:0] P_expected;
   /* Instantiate the DUT */
   DSP48A1Module #(.AOREG(AOREG),.A1REG(A1REG),
                    .BOREG(BOREG),.B1REG(B1REG),
                    .CREG(CREG),.DREG(DREG),
```

```
.MREG(MREG),.PREG(PREG),
                .CARRYINREG(CARRYINREG),.CARRYOUTREG(CARRYOUTREG),
               .OPMODEREG(OPMODEREG),
               .CARRYINSEL(CARRYINSEL),.B_INPUT(B_INPUT),
               .RSTTYPE(RSTTYPE))
               DUT (.*);
/* Clock Generation */
initial begin
    clk = 0;
    forever begin
    #5; clk = ~clk;
end
/* DIRECTED and RANDOMIZED TESTBENCH */
initial begin
   $display ("START THE SIMULATION");
   $display ("----");
   /* Initialize Inputs */
   A = 0; B = 0; D = 0; C = 0;
   CARRYIN = 0; OPMODE = 0;
   CEA = 0; CEB = 0; CEC = 0;
   CED = 0; CEM = 0; CEP = 0;
   CEOPMODE = 0; CECARRYIN = 0;
   RSTA = 0; RSTB = 0; RSTC = 0;
   RSTD = 0; RSTM = 0; RSTP = 0;
   RSTOPMODE = 0; RSTCARRYIN = 0;
   BCIN = 0; PCIN = 0;
   repeat(3) @(negedge clk);
   /* Check the reset functionality */
   // Initialize all the inputs by 1
   A = 1; B = 1; D = 1; C = 1;
   CARRYIN = 1; OPMODE = 1;
   CEA = 1; CEB = 1; CEC = 1;
   CED = 1; CEM = 1; CEP = 1;
   CEOPMODE = 1; CECARRYIN = 1;
   // Initialize reset by 1
   RSTA = 1; RSTB = 1; RSTC = 1;
   RSTD = 1; RSTM = 1; RSTP = 1;
   RSTOPMODE = 1; RSTCARRYIN = 1;
   repeat(3) @(negedge clk);
   // Check the reset functionality
   $display ("Reset_functionality TEST");
   self_checker(P,0);
   $display ("----");
```

```
RSTA = 0; RSTB = 0; RSTC = 0;
RSTD = 0; RSTM = 0; RSTP = 0;
RSTOPMODE = 0; RSTCARRYIN = 0;
/* PRE-ADDER output (Addition) */
A = 18'd1;
B = 18'd5;
D = 18'd3;
C = 48'd100;
OPMODE = 8'b0001_0001;
repeat(4) @(negedge clk);
$display("PRE_ADDER_Addition TEST");
self_checker(P,(B + D) * A);
repeat(2) @(negedge clk);
$display ("----");
/* PRE-ADDER output (Subtraction) */
A = 18'd1;
B = 18'd10;
D = 18'd15;
OPMODE = 8'b0101_0001;
repeat(4) @(negedge clk);
$display("PRE_ADDER_Subtraction TEST");
self_checker(P,(D - B));
repeat(2) @(negedge clk);
$display ("----");
/* MULTIPLIER output */
A = 18'd3;
B = 18'd4;
C = 48'd0;
D = 18'd0;
OPMODE = 8'b0000_0001;
repeat(4) @(negedge clk);
$display("MULTIPLIER TEST");
self_checker(P,(A * B));
repeat(2) @(negedge clk);
$display ("----");
/* POST-ADDER output (Addition) */
A = 18'd5;
B = 18'd6;
C = 48'd50;
OPMODE = 8'b0000_1101;
repeat(4) @(negedge clk);
$display("POST_ADDER_Addition TEST");
self_checker(P,((A * B) + C));
repeat(2) @(negedge clk);
$display ("----");
```

```
/* POST-ADDER output (Subtraction) */
       A = 18'd8;
       B = 18'd2;
       D = 18'd0;
       C = 48'd50;
       OPMODE = 8'b1010 1101;
       repeat(4) @(negedge clk);
       $display("POST_ADDER_Subtraction TEST");
       self_checker(P,(C - ((A * B) + OPMODE[5])));
       repeat(2) @(negedge clk);
       $display ("----");
       $display ("END OF SIMULATION");
       $stop;
   /* Self Checking Task */
   task self_checker(input [47:0] out,expected);
       begin
           if(expected != out) begin
               $display("Error: Expected %d, got %d", expected, out);
               $stop;
           else
               $display("Self Checker: Passed");
       end
   endtask
   /* Monitor the inputs and outputs */
   /* initial begin
        $monitor("OPMODE = %b,A = %d,B = %d, C = %d, D = %d, P = %d",
endmodule
```

## 1.3 Do file

```
vlib work

vlog DSP48A1Module.v DSP48A1Module_tb.v

vsim -voptargs=+acc work.DSP48A1Module_tb

# add Internal signals
add wave DUT/*

run -all
```

## 1.4 Waveform





#### 1.5 Constraint File

```
## Clock signal
# w5 PIN CONNECTED TO CLOCK 33 IS THE DEFNITION OF 3.3v PASSED TO PINS
set_property -dict {PACKAGE_PIN W5 IOSTANDARD LVCMOS33} [get_ports clk]
#add The name of clock in design after -name
create_clock -period 10.00 -name clk -waveform {0.000 5.000} -add [get_ports clk]
```

## 1.6 RTL snippets



## 1.7 Elaboration messages



## 1.8 Synthesis Schematic



## 1.9 Synthesis Messages

Enable and rst of reg\_mux\_pipeline design for A0,B0 as they are connected to the input directly without creating a
register due to parameters

```
parameter AOREG = 0, parameter BOREG = 0, // Default: NO registers
```

- o CARRYIN are unconnected by design due to the parameter of { parameter CARRYINSEL = "OPMODE5"} once it changes to "CARRYIN", They will be connected to them.
- O BCIN are unconnected by design due to the parameter of { parameter B\_INPUT = "DIRECT" } once it changes to "CASCADE", They will be connected to them.

| Name                   | Severity    | Details                                                                                                                    |
|------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Vivado_Tcl 4-<br>321   | Status      | Starting synth_design                                                                                                      |
| Common 17-<br>347      | Status      | Attempting to get a license for feature 'Synthesis' and/or device 'xc7a200t'                                               |
| Project 1-262          | Status      | Processing XDC Constraints                                                                                                 |
| Project 1-569          | Status      | Initializing timing engine                                                                                                 |
| Designutils 20-<br>179 | Status      | Parsing XDC File [F:/Electronics/Digital Electronics - KW/Mini_project_DSP48A1/DSP_CONSTRAINT_FILE.xdc]                    |
| Designutils 20-<br>178 | Status      | Finished Parsing XDC File [F:/Electronics/Digital Electronics - KW/Mini_project_DSP48A1/DSP_CONSTRAINT_FILE.xdc]           |
| Project 1-263          | Status      | Completed Processing XDC Constraints                                                                                       |
| Vivado_Tcl 4-<br>41    | Status      | 29 Infos, 41 Warnings, 0 Critical Warnings and 0 Errors encountered.                                                       |
| Vivado_Tcl 4-<br>42    | Status      | synth_design completed successfully                                                                                        |
| #UNDEF                 | Status      | report_utilization: Time (s): cpu = $00:00:00$ ; elapsed = $00:00:00.082$ . Memory (MB): peak = $906.184$ ; gain = $0.000$ |
| Common 17-<br>349      | Information | Got license for feature 'Synthesis' and/or device 'xc7a200t'                                                               |
| Synth 8-6157           | Information | synthesizing module 'reg_mux_pipeline'                                                                                     |
| Synth 8-6157           | Information | synthesizing module 'reg_mux_pipelineparameterized0'                                                                       |
| Synth 8-6157           | Information | synthesizing module 'reg_mux_pipelineparameterized1'                                                                       |
| Synth 8-6157           | Information | synthesizing module 'reg_mux_pipelineparameterized2'                                                                       |
| Synth 8-6157           | Information | synthesizing module 'reg_mux_pipelineparameterized3'                                                                       |
| Synth 8-6157           | Information | synthesizing module 'reg_mux_pipelineparameterized4'                                                                       |
| Synth 8-6155           | Information | done synthesizing module 'reg_mux_pipelineparameterized0' (1#1)                                                            |
| Synth 8-6155           | Information | done synthesizing module 'reg_mux_pipelineparameterized1' (1#1)                                                            |
| Synth 8-6155           | Information | done synthesizing module 'reg_mux_pipelineparameterized2' (1#1)                                                            |
| Synth 8-6155           | Information | done synthesizing module 'reg_mux_pipelineparameterized3' (1#1)                                                            |
| Synth 8-6155           | Information | done synthesizing module 'reg_mux_pipelineparameterized4' (1#1)                                                            |
| Synth 8-6155           | Information | done synthesizing module 'DSP48A1Module' (2#1)                                                                             |
| Synth 8-3331           | Warning     | design reg_mux_pipeline has unconnected port enable                                                                        |
| Synth 8-3331           | Warning     | design reg_mux_pipeline has unconnected port rst                                                                           |
| Synth 8-3331           | Warning     | design DSP48A1Module has unconnected port CARRYIN                                                                          |

| Project 1-236        | Information | Implementation specific constraints were found while reading constraint file [F:/Electronics/Digital Electronics - KW/Mini_project_DSP48A1/DSP_CONSTRAINT_FILE.xdc]. These constraints will be ignored for synthesis but will be used in implementation. Impacted constraints are listed in the file [.Xil/DSP48A1Module_propImpl.xdc]. |
|----------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Device 21-403</b> | Information | Loading part xc7a200tffg1156-3                                                                                                                                                                                                                                                                                                          |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[0]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[1]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[2]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[3]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[4]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[5]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[6]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[7]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[8]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[9]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[10]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[11]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[12]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[13]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[14]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[15]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[16]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[17]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port CARRYIN                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[0]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[1]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[2]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[3]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[4]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[5]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[6]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[7]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[8]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[9]                                                                                                                                                                                                                                                                                       |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[10]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[11]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[12]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[13]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[14]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[15]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[17]                                                                                                                                                                                                                                                                                      |
| Synth 8-3331         | Warning     | design DSP48A1Module has unconnected port BCIN[17]                                                                                                                                                                                                                                                                                      |

|                        |             | Resolution: To avoid this warning, move constraints listed in ['Undefined'] to another XDC file and exclude this new file from synthesis with the used_in_synthesis property (File Properties dialog in GUI) and re-run elaboration/synthesis. |
|------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Synth 8-5818           | Information | HDL ADVISOR - The operator resource <adder> is shared. To prevent sharing consider applying a KEEP on the output of the operator</adder>                                                                                                       |
| Synth 8-5842           | Information | Cannot pack DSP OPMODE registers because of constant '1' value. Packing the registers will cause simulation mismatch at initial cycle                                                                                                          |
| Project 1-571          | Information | Translating synthesized netlist                                                                                                                                                                                                                |
| Netlist 29-17          | Information | Analyzing 207 Unisim elements for replacement                                                                                                                                                                                                  |
| Netlist 29-28          | Information | Unisim Transformation completed in 0 CPU seconds                                                                                                                                                                                               |
| Project 1-570          | Information | Preparing netlist for logic optimization                                                                                                                                                                                                       |
| Opt 31-138             | Information | Pushed 0 inverter(s) to 0 load pin(s).                                                                                                                                                                                                         |
| Project 1-111          | Information | Unisim Transformation Summary:<br>No Unisim elements were transformed.                                                                                                                                                                         |
| <b>Common 17-83</b>    | Information | Releasing license: Synthesis                                                                                                                                                                                                                   |
| Constraints<br>18-5210 | Warning     | No constraint will be written out.                                                                                                                                                                                                             |
| Common 17-<br>1381     | Information | The checkpoint 'F:/Electronics/Digital Electronics - KW/Mini_project_DSP48A1/DSP48A1/DSP48A1.runs/synth_1/DSP48A1Module.dcp' has been generated.                                                                                               |
| runtcl-4               | Information | Executing : report_utilization -file DSP48A1Module_utilization_synth.rpt -pb DSP48A1Module_utilization_synth.pb                                                                                                                                |
| Common 17-<br>206      | Information | Exiting Vivado at Sun Jul 28 02:59:45 2024                                                                                                                                                                                                     |

## 1.10 Synthesis Utilization report

| Name                           | Slice LUTs<br>(134600) | Slice Registers<br>(269200) | DSPs (740) | Bonded IOB<br>(500) | BUFGCTRL<br>(32) |
|--------------------------------|------------------------|-----------------------------|------------|---------------------|------------------|
| ∨ N DSP48A1Module              | 230                    | 160                         | 1          | 327                 | 1                |
| In_P (reg_mux_pipelin          | 0                      | 48                          | 0          | 0                   | 0                |
| In_OPMODE (reg_mux             | 228                    | 8                           | 0          | 0                   | 0                |
| <b>I</b> in_M (reg_mux_pipelin | 0                      | 0                           | 1          | 0                   | 0                |
| In_D (reg_mux_pipelin          | 0                      | 18                          | 0          | 0                   | 0                |
| I in_CYO (reg_mux_pip          | 0                      | 1                           | 0          | 0                   | 0                |
| In_CYI (reg_mux_pipel          | 1                      | 1                           | 0          | 0                   | 0                |
| In_C (reg_mux_pipelin          | 0                      | 48                          | 0          | 0                   | 0                |
| In_B1 (reg_mux_pipeli          | 0                      | 18                          | 0          | 0                   | 0                |
| <b>I</b> in_A1 (reg_mux_pipeli | 0                      | 18                          | 0          | 0                   | 0                |

| Resource | Utilization | Available | Utilization % |
|----------|-------------|-----------|---------------|
| LUT      | 230         | 134600    | 0.17          |
| FF       | 160         | 269200    | 0.06          |
| DSP      | 1           | 740       | 0.14          |
| IO       | 327         | 500       | 65.40         |



## 1.11 Synthesis Timing Report



## 1.12 Implementation Schematic



#### 1.13 Implementation Messages



## 1.14 Implementation Utilization Report

| Name 1                  | Slice LUTs<br>(133800) | Slice Registers<br>(267600) | Slice<br>(3345<br>0) | LUT as Logic<br>(133800) | LUT Flip Flop Pairs<br>(133800) | DSP<br>s<br>(740<br>) | Bonded IOB<br>(500) | BUFGCTRL<br>(32) |
|-------------------------|------------------------|-----------------------------|----------------------|--------------------------|---------------------------------|-----------------------|---------------------|------------------|
| ∨ N DSP48A1Module       | 229                    | 179                         | 98                   | 229                      | 50                              | 1                     | 327                 | 1                |
| I in_A1 (reg_mux_pipeli | 0                      | 18                          | 6                    | 0                        | 0                               | 0                     | 0                   | 0                |
| In_B1 (reg_mux_pipeli   | 0                      | 36                          | 10                   | 0                        | 0                               | 0                     | 0                   | 0                |
| In_C (reg_mux_pipelin   | 0                      | 48                          | 14                   | 0                        | 0                               | 0                     | 0                   | 0                |
| In_CYI (reg_mux_pipel   | 1                      | 1                           | 1                    | 1                        | 1                               | 0                     | 0                   | 0                |
| In_CYO (reg_mux_pip     | 0                      | 2                           | 2                    | 0                        | 0                               | 0                     | 0                   | 0                |
| In_D (reg_mux_pipelin   | 0                      | 18                          | 10                   | 0                        | 0                               | 0                     | 0                   | 0                |
| In_M (reg_mux_pipelin   | 0                      | 0                           | 0                    | 0                        | 0                               | 1                     | 0                   | 0                |
| In_OPMODE (reg_mux      | 228                    | 8                           | 75                   | 228                      | 0                               | 0                     | 0                   | 0                |
| In_P (reg_mux_pipelin   | 0                      | 48                          | 12                   | 0                        | 0                               | 0                     | 0                   | 0                |

## Summary

| Resource | Utilization | Available | Utilization % |
|----------|-------------|-----------|---------------|
| LUT      | 229         | 133800    | 0.17          |
| FF       | 179         | 267600    | 0.07          |
| DSP      | 1           | 740       | 0.14          |
| IO       | 327         | 500       | 65.40         |



# 1.15 Implementation Timing Report

#### **Design Timing Summary**

| tup                          |          | Hold                         |          | Pulse Width                              |          |  |
|------------------------------|----------|------------------------------|----------|------------------------------------------|----------|--|
| Worst Negative Slack (WNS):  | 3.858 ns | Worst Hold Slack (WHS):      | 0.273 ns | Worst Pulse Width Slack (WPWS):          | 4.500 ns |  |
| Total Negative Slack (TNS):  | 0.000 ns | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |  |
| Number of Failing Endpoints: | 0        | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |  |
| Total Number of Endpoints:   | 106      | Total Number of Endpoints:   | 106      | Total Number of Endpoints:               | 181      |  |